<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <meta http-equiv="X-UA-Compatible" content="ie=edge" />
    <title>清除浮动</title>
    <style>
      .container {
        width: 600px;
        margin: 0 auto;
      }
      .item {
        width: 600px;
        height: 300px;
      }
      .parent {
        width: 600px;
        background-color: burlywood;
        margin: 20px auto;
        border: 2px solid #afadad;
      }
      .child {
        margin: 10px;
        width: 100px;
        height: 100px;
        background-color: coral;
        border: 2px solid #afadad;
      }
      .fleft {
        float: left;
      }

      .clearfix::after {
        display: block;
        clear: both;
        content: "";
        visibility: hidden;
        height: 0;
      }
      .clearfix {
        zoom: 1;
      }
    </style>
  </head>
  <body>
    <section class="container">
      <!-- 文档流状态下 -->
      <div class="item">
        <div class="parent ">
          文档流状态下两个div的排列
          <div class="child "></div>
          <div class="child "></div>
        </div>
      </div>
      <hr />

      <!-- 浮动状态下 -->
      <div class="item">
        <div class="parent ">
          一个div浮动下的排列
          <div class="child "></div>
          <div class="child fleft">我浮动了</div>
        </div>
        为什么要清楚浮动？因为浮动会引起高度塌陷
      </div>
      <hr />

      <!-- 清楚浮动的方式 -->
      <!-- 第一种：直接给我父元素增加一定的高度，解决高度塌陷的问题 -->
      <div class="item">
        <div class="parent" style="height: 300px;">
          第一种：直接给我父元素增加一定的高度，解决高度塌陷的问题<br />
          总结：没有实际上解决浮动问题
          <div class="child "></div>
          <div class="child fleft">我浮动了</div>
        </div>
      </div>
      <hr />

      <!-- 第二种：增加子元素 -->
      <div class="item">
        <div class="parent ">
          第二种：增加子元素，设置子元素的样式为clear:both <br />
          总结：会增加一个DOM节点,不够优雅
          <div class="child "></div>
          <div class="child fleft">我浮动了</div>
          <div style="clear:both;"></div>
        </div>
      </div>
      <hr />

      <!-- 第三种： 为父元素设置overflow：hidden； -->
      <div class="item">
        <div class="parent" style="overflow:hidden;">
          第三种：父元素设置
          overflow:hidden（如果你还要兼顾IE6的话，加上*zoom:1;来触发hasLayout）
          <br />
          总结：理论实现来源于BFC,难于理解，易于使用
          <div class="child "></div>
          <div class="child fleft">我浮动了</div>
        </div>
      </div>
      <hr />

      <!-- 第四种：用：after 伪元素 -->
      <div class="item">
        <div class="parent clearfix">
          第三种：用:after伪元素，思路是用:after元素在div后面插入一个隐藏文本”
          ”，隐藏文本用clear来实现闭合浮动：<br />
          总结：结构和语义化完全正确，代码略复杂。 (推荐)
          <div class="child "></div>
          <div class="child fleft">我浮动了</div>
        </div>
      </div>
      <hr />
    </section>
  </body>
</html>
